home *** CD-ROM | disk | FTP | other *** search
/ Apple WWDC 1996 / WWDC96_1996 (CD).toast / Technology Materials / MacOS 8 Resources / Developer Tools / Mac OS 8 Interfaces & Libraries / Interfaces / CIncludes / fp.h < prev    next >
C/C++ Source or Header  |  1996-05-01  |  28KB  |  627 lines

  1. /*******************************************************************************
  2. *                                                                              *
  3. *      File fp.h   -   PowerPC and 68K Macintosh                               *
  4. *                                                                              *
  5. *      A collection of numerical functions designed to facilitate a wide       *
  6. *      range of numerical programming. It is modeled after the Floating-Point  *
  7. *      C Extensions (FPCE) proposed technical draft of the Numerical C         *
  8. *      Extensions Group's requirements (NCEG / X3J11.1).                       *
  9. *      The <fp.h> declares many functions in support of numerical programming. *
  10. *      It provides a superset of <math.h> and <sane.h> functions.  Some        *
  11. *      functionality previously found in <sane.h> and not in the FPCE <fp.h>   *
  12. *      can be found in this <fp.h> under the heading "__NOEXTENSIONS__".       *
  13. *                                                                              *
  14. *      All of these functions are IEEE 754 aware and treat exceptions, NaNs,   *
  15. *      positive and negative zero and infinity consistent with the floating-   *
  16. *      point standard.                                                         *
  17. *                                                                              *
  18. *      Copyright © 1992-1995 Apple Computer, Inc.  All rights reserved.        *
  19. *                                                                              *
  20. *      Written by Ali Sazegari, started on July 1992,                          *
  21. *      based on the file Numerics.h by Jim Thomas.                             *
  22. *                                                                              *
  23. *      October    27  1992: made changes for PowerPC, transfered some power    *
  24. *                           functions to <faux.h>.                             *
  25. *      October    30  1992: added long double data type for PowerPC and        *
  26. *                           merged it with the Macintosh <fp.h>.               *
  27. *      December   10  1992: changed logb, scalb, frexp and ldexp to            *
  28. *                           LOGB, SCALB, FREXP and LDEXP to avoid collision    *
  29. *                           with the ibm libc.                                 *
  30. *      December   16  1992: changed the flag "powerpc" to "powerc"             *
  31. *      February   17  1993: removed the typedefs and defrerred them to         *
  32. *                           <Types.h>.                                         *
  33. *      May        18  1993: added binary to decimal conversions for the        *
  34. *                           PowerPC.                                           *
  35. *      June       14  1993: added the long double decimal conversions, changed *
  36. *                           the decimal conversion prototypes to double_t.     *
  37. *      July       11  1993: changed the names of the long double bin2dec.      *
  38. *      August     23  1993: included C++ extern "C" wrappers to make them C++  *
  39. *                           friendly.                                          *
  40. *      November   29  1993: corrected a spelling mistake in the comments.      *
  41. *      February   22  1994: modf changed to double_t for 68K compatability PAF *
  42. *      February   22  1994: Comment changes PAF                                *
  43. *      April      26  1994: #define SIGDIGLEN 20 for 68K PAF                   *
  44. *      April      28  1994: collected all powerpc specific calls, changed      *
  45. *                           DECIMAL_DIG to 17.                                 *             
  46. *      May         2  1994: Added dec2d prototype and function to fp68K.c      *
  47. *      May         4  1994: Added #ifndef powerc prototype for trunc           *
  48. *      June       23  1994: Changed __inf() prototype to double_t.             *
  49. *     January    17  1995: Remove C++ comments.  Use ConditionalMacros.h      *
  50. *      March      29  1995: Added definitions for 68k based transfer functions *
  51. *                           and MathLib v2 double to 68k long double transfer  *
  52. *                           functions.  Corrected some comments.               *
  53. *      October    11  1995: changed an #ifdef to #if in a macro definition.    *
  54. *                                                                              *
  55. *******************************************************************************/
  56.  
  57. #ifndef __FP__
  58. #define __FP__
  59.  
  60. /*      efficient types are included in Types.h.                              */
  61.  
  62. #ifndef __TYPES__
  63. #include <Types.h>
  64. #endif
  65.  
  66. /*******************************************************************************
  67. *                              Define some constants.                          *
  68. *******************************************************************************/
  69.  
  70. #if          GENERATINGPOWERPC
  71. #define      LONG_DOUBLE_SIZE         16
  72. #elif       GENERATING68881
  73. #define      LONG_DOUBLE_SIZE         12
  74. #else
  75. #define      LONG_DOUBLE_SIZE         10
  76. #endif  
  77.  
  78. #define      DOUBLE_SIZE               8      
  79.  
  80. #define      HUGE_VAL                  __inf()
  81. #define      INFINITY                  __inf()
  82. #define      NAN                        nan("255")
  83.  
  84. /*    the macro DECIMAL_DIG is obtained by satisfying the constraint that the
  85.       conversion from double to decimal and back is the identity function.   */
  86.  
  87. #if          GENERATINGPOWERPC
  88. #define      DECIMAL_DIG              17 /* does not exist for double-double */
  89. #else
  90. #define      DECIMAL_DIG              21
  91. #endif      
  92.  
  93. #ifdef __cplusplus
  94. extern "C" {
  95. #endif
  96. /*******************************************************************************
  97. *                            Trigonometric functions                           *
  98. *******************************************************************************/
  99.  
  100. double_t cos ( double_t x );
  101. double_t sin ( double_t x );
  102. double_t tan ( double_t x );
  103.  
  104. double_t acos ( double_t x );                /*  result is in [0,pi]          */
  105. double_t asin ( double_t x );                /*  result is in [-pi/2,pi/2]    */
  106. double_t atan ( double_t x );                /*  result is in [-pi/2,pi/2]    */
  107.  
  108. /*    atan2 computes the arc tangent of y/x in [-pi,pi] using the sign of
  109.       both arguments to determine the quadrant of the computed value.         */
  110.  
  111. double_t atan2 ( double_t y, double_t x );
  112.  
  113. /*******************************************************************************
  114. *                              Hyperbolic functions                            *
  115. *******************************************************************************/
  116.  
  117. double_t cosh ( double_t x );
  118. double_t sinh ( double_t x );
  119. double_t tanh ( double_t x );
  120.  
  121. double_t acosh ( double_t x );
  122. double_t asinh ( double_t x );
  123. double_t atanh ( double_t x );
  124.  
  125. /*******************************************************************************
  126. *                              Exponential functions                           *
  127. *******************************************************************************/
  128.  
  129. double_t exp ( double_t x );
  130.  
  131. /*    expm1 computes the base e exponential of the argument minus 1,
  132.       i. e., exp(x) - 1.  For small enough arguments, expm1 is expected
  133.       to be more accurate than the straight forward computation of exp(x) - 1.*/
  134.  
  135. double_t expm1  ( double_t x );
  136. double_t exp2  ( double_t x );
  137.  
  138. double_t frexp ( double_t x, int *exponent );
  139. double_t ldexp ( double_t x, int n );
  140.  
  141. double_t log ( double_t x );
  142. double_t log2 ( double_t x );
  143.  
  144. /*    log1p computes the base e logorithm of 1 plus the argument,
  145.       i. e., log (1+x).  For small enough arguments, log1p is expected
  146.       to be more accurate than the straightforward computation of log (1+x).  */
  147.  
  148. double_t log1p ( double_t x );
  149. double_t log10 ( double_t x ); 
  150.  
  151. /*    logb extracts the exponent of its argument, as a signed integral
  152.       value. A subnormal argument is treated as though it were first
  153.       normalized. Thus
  154.  
  155.       1 <= x * 2^( - Logb ( x ) ) < 2                                         */
  156.  
  157. double_t logb ( double_t x );
  158.  
  159. long double modfl ( long double x, long double *iptrl );
  160. double_t    modf  ( double_t x, double_t *iptr );  /* <- note NCEG difference */
  161. float       modff ( float x, float *iptrf );
  162.  
  163. /*    scalb computes x * 2^n efficently.  This is not normally done by
  164.       computing 2^n explicitly.                                               */
  165.  
  166. double_t scalb ( double_t x, long int n ); 
  167.  
  168. /*******************************************************************************
  169. *                     Power and absolute value functions                       *
  170. *******************************************************************************/
  171.  
  172. double_t fabs ( double_t x );
  173.  
  174. /*    hypot computes the square root of the sum of the squares of its
  175.       arguments, without undue overflow or underflow.                         */
  176.  
  177. double_t hypot ( double_t x, double_t y );
  178. double_t pow   ( double_t x, double_t y );
  179. double_t sqrt  ( double_t x );
  180.  
  181. /*******************************************************************************
  182. *                        Gamma and Error functions                             *
  183. *******************************************************************************/
  184.  
  185. double_t erf  ( double_t x );            /*   the error function              */
  186. double_t erfc ( double_t x );            /*   complementary error function    */
  187.  
  188. double_t gamma ( double_t x );
  189.  
  190. /*    lgamma computes the base-e logarithm of the absolute value of
  191.       gamma of its argument x, for x > 0.                                     */
  192.  
  193. double_t lgamma ( double_t x );
  194.  
  195. /*******************************************************************************
  196. *                        Nearest integer functions                             *
  197. *******************************************************************************/
  198.  
  199. double_t ceil  ( double_t x );
  200. double_t floor ( double_t x ); 
  201.  
  202. /*    the rint function rounds its argument to an integral value in floating
  203.       point format, honoring the current rounding direction.                  */
  204.  
  205. double_t rint ( double_t x );
  206.  
  207. /*    nearbyint differs from rint only in that it does not raise the
  208.       inexact exception. It is the nearbyint function recommended by the
  209.       IEEE floating-point standard 854.                                       */
  210.  
  211. double_t nearbyint ( double_t x );
  212.  
  213. /*    the function rinttol rounds its argument to the nearest long int using
  214.       the current rounding direction.
  215.       >>Note that if the rounded value is outside the range of long int, then
  216.       the result is undefined.                                                */
  217.  
  218. long int rinttol ( double_t x );
  219.  
  220. /*    the round function rounds the argument to the nearest integral value
  221.       in double format similar to the Fortran "anint" function.  That is:
  222.       add half to the magnitude and chop.                                     */
  223.  
  224. double_t round ( double_t x );
  225.  
  226. /*    roundtol is similar to the Fortran function nint or to the Pascal round
  227.       >>Note that if the rounded value is outside the range of long int, then
  228.       the result is undefined.                                                */
  229.  
  230. long int roundtol ( double_t round );
  231.  
  232. /*    trunc computes the integral value, in floating format, nearest to
  233.       but no larger in magnitude than its argument.                           */
  234.  
  235. #if  GENERATING68K
  236. /* necessary because trunc is implicitly declared this way when -elems881 is set */
  237. int      trunc ( double_t x );      /*  Round to integer in direction of zero */
  238. #else
  239. double_t trunc ( double_t x );
  240. #endif
  241.  
  242. /*******************************************************************************
  243. *                            Remainder functions                               *
  244. *******************************************************************************/
  245.  
  246. double_t fmod ( double_t x, double_t y );
  247.  
  248. /*    the following two functions compute the remainder.  remainder is required
  249.       by the IEEE 754 floating point standard. The second form correponds to the
  250.       SANE remainder; it stores into 'quotient' the 7 low-order bits of the
  251.       integer quotient x/y, such that -127 <= quotient <= 127.                */
  252.  
  253. double_t remainder ( double_t x, double_t y );
  254. double_t remquo    ( double_t x, double_t y, int *quo );
  255.  
  256. /*******************************************************************************
  257. *                             Auxiliary functions                              *
  258. *******************************************************************************/
  259.  
  260. /*    copysign produces a value with the magnitude of its first argument
  261.       and sign of its second argument. NOTE: the order of the arguments
  262.       matches the recommendation of the IEEE 754 floating point standard,
  263.       which is opposite from the SANE copysign function.                      */
  264.  
  265. double_t copysign ( double_t x, double_t y );
  266.  
  267. /*    the call 'nan ( "n-char-sequence" )' returns a quiet NaN with content
  268.       indicated through tagp in the selected data type format.                */
  269.  
  270. long double nanl ( const char *tagp );
  271. double      nan  ( const char *tagp );
  272. float       nanf ( const char *tagp );
  273.  
  274. /*    these compute the next representable value, in the type indicated,
  275.       after 'x' in the direction of 'y'.  if x == y then y is returned.       */
  276.  
  277. long double nextafterl ( long double x, long double y );
  278. double      nextafterd ( double x, double y );
  279. float       nextafterf ( float x, float y );
  280.  
  281. /*******************************************************************************
  282. *                              Inquiry macros                                  *
  283. *******************************************************************************/
  284.  
  285. enum NumberKind
  286.             {
  287.             FP_SNAN = 0,        /*      signaling NaN                         */
  288.             FP_QNAN,            /*      quiet NaN                             */
  289.             FP_INFINITE,        /*      + or - infinity                       */
  290.             FP_ZERO,            /*      + or - zero                           */
  291.             FP_NORMAL,          /*      all normal numbers                    */
  292.             FP_SUBNORMAL        /*      denormal numbers                      */
  293.             };
  294.  
  295. #define      fpclassify(x)    ( ( sizeof ( x ) == LONG_DOUBLE_SIZE ) ?         \
  296.                               __fpclassify  ( x ) :                            \
  297.                                 ( sizeof ( x ) == DOUBLE_SIZE ) ?              \
  298.                               __fpclassifyd ( x ) :                            \
  299.                               __fpclassifyf ( x ) )
  300.  
  301. /*    isnormal is non-zero if and only if the argument x is normalized.       */
  302.  
  303. #define      isnormal(x)      ( ( sizeof ( x ) == LONG_DOUBLE_SIZE ) ?         \
  304.                               __isnormal ( x ) :                               \
  305.                                 ( sizeof ( x ) == DOUBLE_SIZE ) ?              \
  306.                               __isnormald ( x ) :                              \
  307.                               __isnormalf ( x ) )
  308.  
  309. /*    isfinite is non-zero if and only if the argument x is finite.           */
  310.  
  311. #define      isfinite(x)      ( ( sizeof ( x ) == LONG_DOUBLE_SIZE ) ?         \
  312.                               __isfinite ( x ) :                               \
  313.                                 ( sizeof ( x ) == DOUBLE_SIZE ) ?              \
  314.                               __isfinited ( x ) :                              \
  315.                               __isfinitef ( x ) )
  316.  
  317. /*    isnan is non-zero if and only if the argument x is a NaN.               */
  318.  
  319. #define      isnan(x)         ( ( sizeof ( x ) == LONG_DOUBLE_SIZE ) ?         \
  320.                               __isnan ( x ) :                                  \
  321.                               ( sizeof ( x ) == DOUBLE_SIZE ) ?                \
  322.                               __isnand ( x ) :                                 \
  323.                               __isnanf ( x ) )
  324.  
  325. /*    signbit is non-zero if and only if the sign of the argument x is
  326.       negative. this includes, NaNs, infinities and zeros.                    */
  327.  
  328. #define      signbit(x)       ( ( sizeof ( x ) == LONG_DOUBLE_SIZE ) ?         \
  329.                               __signbit ( x ) :                                \
  330.                               ( sizeof ( x ) == DOUBLE_SIZE ) ?                \
  331.                               __signbitd ( x ) :                               \
  332.                               __signbitf ( x ) )
  333.  
  334. /*******************************************************************************
  335. *                      Max, Min and Positive Difference                        *
  336. *******************************************************************************/
  337.  
  338. /*    These extension functions correspond to the standard functions, dim
  339.       max and min.
  340.  
  341.       The fdim function determines the 'positive difference' between its
  342.       arguments: { x - y, if x > y }, { +0, if x <= y }.  If one argument is
  343.       NaN, then fdim returns that NaN.  if both arguments are NaNs, then fdim
  344.       returns the first argument.                                             */
  345.  
  346. double_t fdim ( double_t x, double_t y );
  347.  
  348. /*    max and min return the maximum and minimum of their two arguments,
  349.       respectively.  They correspond to the max and min functions in FORTRAN.
  350.       NaN arguments are treated as missing data.  If one argument is NaN and
  351.       the other is a number, then the number is returned.  If both are NaNs
  352.       then the first argument is returned.                                    */
  353.  
  354. double_t fmax ( double_t x, double_t y );
  355. double_t fmin ( double_t x, double_t y );
  356.  
  357. /*******************************************************************************
  358. *                                Constants                                     *
  359. *******************************************************************************/
  360.  
  361. extern const double_t pi;
  362.  
  363. /*******************************************************************************
  364. *                              Internal prototypes                             *
  365. *******************************************************************************/
  366.  
  367. long int __fpclassify  ( long double x ); 
  368. long int __fpclassifyd ( double x );
  369. long int __fpclassifyf ( float x );
  370.  
  371. long int __isnormal  ( long double x );
  372. long int __isnormald ( double x );
  373. long int __isnormalf ( float x );
  374.  
  375. long int __isfinite  ( long double x );
  376. long int __isfinited ( double x );
  377. long int __isfinitef ( float x );
  378.  
  379. long int __isnan  ( long double x );
  380. long int __isnand ( double x );
  381. long int __isnanf ( float x );
  382.  
  383. long int __signbit  ( long double x );
  384. long int __signbitd ( double x );
  385. long int __signbitf ( float x );
  386.  
  387. double_t __inf ( void );
  388.  
  389. /*******************************************************************************
  390. *                              Non NCEG extensions                             *
  391. *******************************************************************************/
  392.  
  393. #ifndef __NOEXTENSIONS__
  394.  
  395. /*******************************************************************************
  396. *                              Financial functions                             *
  397. *******************************************************************************/
  398.  
  399. /*    compound computes the compound interest factor "(1 + rate) ^ periods"
  400.       more accurately than the straightforward computation with the Power
  401.       function.  This is SANE's compound function.                            */
  402.  
  403. double_t compound ( double_t rate, double_t periods );
  404.  
  405. /*    The function annuity computes the present value factor for an annuity 
  406.       "( 1 - ( 1 + rate ) ^ ( - periods ) ) / rate" more accurately than the
  407.       straightforward computation with the Power function. This is SANE's 
  408.       annuity function.                                                       */
  409.  
  410. double_t annuity ( double_t rate, double_t periods );
  411.  
  412. /*******************************************************************************
  413. *                              Random function                                 *
  414. *******************************************************************************/
  415.  
  416. double_t randomx ( double_t *x );
  417.  
  418. /*******************************************************************************
  419. *                              Relational operator                             *
  420. *******************************************************************************/
  421.  
  422. typedef short relop;                         /*      relational operator      */
  423.  
  424. enum 
  425.       {
  426.       GREATERTHAN = ( ( relop ) ( 0 ) ),
  427.       LESSTHAN,
  428.       EQUALTO,
  429.       UNORDERED
  430.       };
  431.  
  432. relop relation ( double_t x, double_t y );
  433.  
  434. /*******************************************************************************
  435. *                         Binary to decimal conversions                        *
  436. *******************************************************************************/
  437.  
  438. #if    GENERATINGPOWERPC
  439. #define      SIGDIGLEN      36               /*    significant decimal digits */
  440. #else
  441. #define      SIGDIGLEN      20               /*    significant decimal digits */
  442. #endif
  443.  
  444. #define      DECSTROUTLEN   80               /* max length for dec2str output */
  445. #define      FLOATDECIMAL   ((char)(0))
  446. #define      FIXEDDECIMAL   ((char)(1))
  447.  
  448. /*    The decimal record type provides an intermediate unpacked form for
  449.       programmers who wish to do their own parsing of numeric input or
  450.       formatting of numeric output.                                           */
  451.     
  452. struct decimal 
  453.      {
  454.       char sgn;                              /*         sign 0 for +, 1 for - */
  455.       char unused;
  456.       short exp;                             /*              decimal exponent */
  457.       struct
  458.             {
  459.             unsigned char length;
  460.             unsigned char text[SIGDIGLEN];   /*            significant digits */
  461.             unsigned char unused;
  462.             }sig;
  463.       };
  464.  
  465. typedef struct decimal decimal;
  466.  
  467. /*    Each conversion to a decimal string is controlled by a decform
  468.       structure.  The style is either FLOATDECIMAL or FIXEDDECIMAL defined
  469.       above.  The value of digits is the number of significant digits for
  470.       FLOATDECIMAL.  The value of digits for FIXEDDECIMAL is the number of
  471.       digits to the right of the decimal point.                               */
  472.  
  473. struct decform 
  474.       {
  475.       char style;                            /*  FLOATDECIMAL or FIXEDDECIMAL */
  476.       char unused;
  477.       short digits;
  478.       };
  479.  
  480. typedef struct decform decform;
  481.  
  482. /*    Each conversion to a decimal record d via the function call num2dec is 
  483.       controlled by a decform record f (defined earlier), to a double_t x.    */
  484.  
  485. void num2dec ( const decform *f, double_t x, decimal *d );
  486.  
  487. /*    dec2num converts a decimal record d to a double_t value.                */
  488.  
  489. double_t dec2num ( const decimal *d );
  490.  
  491. /*    The MathLib formatter dec2str is controlled by a decform f.  Input d is
  492.       a decimal record.                                                       */
  493.  
  494. void dec2str ( const decform *f, const decimal *d, char *s );
  495.  
  496. /*    The function str2dec is the MathLib scanner.                            */
  497.  
  498. void str2dec ( const char *s, short *ix, decimal *d, short *vp ); 
  499.  
  500. /*    dec2d is similar to dec2num except a double is returned on 68k platforms*/
  501.  
  502. #if  GENERATING68K
  503. double dec2d ( const decimal *d );
  504. #endif
  505.  
  506. /*    dec2f is similar to dec2num except a float is returned.                 */
  507.  
  508. float dec2f ( const decimal *d );
  509.  
  510. /*    dec2s is similar to dec2num except a short is returned.                 */
  511.  
  512. short int dec2s ( const decimal *d );
  513.  
  514. /*    dec2l is similar to dec2num except a long is returned.                  */
  515.  
  516. long int dec2l  ( const decimal *d );
  517.  
  518. /*******************************************************************************
  519. *                    68k-only Transfer Function Prototypes                     *
  520. *******************************************************************************/
  521.  
  522. #if GENERATING68K
  523. #if GENERATING68881
  524.  
  525. void x96tox80 ( const long double *x, extended80 *x80 );
  526. void x80tox96 ( const extended80 *x80, long double *x );
  527.  
  528. #else
  529.  
  530. void x96tox80 ( const extended96 *x96, long double *x );
  531. void x80tox96 ( const long double *x, extended96 *x96 );
  532.  
  533. #endif      /* GENERATING68881   */
  534. #endif      /* GENERATING68K */
  535.  
  536. #endif      /* __NOEXTENSIONS__ */
  537.  
  538. /*******************************************************************************
  539. *                         PowerPC-only Function Prototypes                     *
  540. *******************************************************************************/
  541.  
  542. #if  GENERATINGPOWERPC
  543.  
  544. long double cosl ( long double x );
  545. long double sinl ( long double x );
  546. long double tanl ( long double x );
  547.  
  548. long double acosl ( long double x );          /*  result is in [0,pi]         */
  549. long double asinl ( long double x );          /*  result is in [-pi/2,pi/2]   */
  550. long double atanl ( long double x );          /*  result is in [-pi/2,pi/2]   */
  551. long double atan2l ( long double y, long double x );
  552.  
  553. long double coshl ( long double x );
  554. long double sinhl ( long double x );
  555. long double tanhl ( long double x );
  556.  
  557. long double acoshl ( long double x );
  558. long double asinhl ( long double x );
  559. long double atanhl ( long double x );
  560.  
  561. long double expl ( long double x );
  562. long double expm1l ( long double x );
  563. long double exp2l  ( long double x );
  564.  
  565. long double frexpl ( long double x, int *exponent );
  566. long double ldexpl ( long double x, int n );
  567.  
  568. long double logl ( long double x );
  569. long double log1pl ( long double x );
  570. long double log10l ( long double x ); 
  571. long double log2l ( long double x );
  572.  
  573. long double logbl ( long double x );
  574. long double scalbl ( long double x, long int n ); 
  575.  
  576. long double fabsl ( long double x );
  577. long double hypotl ( long double x, long double y );
  578. long double powl   ( long double x, long double y );
  579. long double sqrtl  ( long double x );
  580.  
  581. long double erfl  ( long double x );     /*   the error function              */
  582. long double erfcl ( long double x );     /*   complementary error function    */
  583. long double gammal ( long double x );
  584. long double lgammal ( long double x );
  585.  
  586. long double ceill  ( long double x );
  587. long double floorl ( long double x );
  588. long double rintl ( long double x );
  589. long double nearbyintl ( long double x );
  590. long int rinttoll ( long double x );
  591. long double roundl ( long double x );
  592. long int roundtoll ( long double round );
  593. long double truncl ( long double x );
  594. long double remainderl ( long double x, long double y );
  595. long double remquol    ( long double x, long double y, int *quo );
  596. long double copysignl ( long double x, long double y );
  597. long double fdiml ( long double x, long double y );
  598. long double fmaxl ( long double x, long double y );
  599. long double fminl ( long double x, long double y );
  600.  
  601. #ifndef __NOEXTENSIONS__
  602.  
  603. relop relationl ( long double x, long double y );
  604. void x80told ( const extended80 *x80, long double *x );
  605. void ldtox80 ( const long double *x, extended80 *x80 );
  606.  
  607. /*    MathLib v2 has two new transfer functions: x80tod and dtox80.  They can 
  608.       be used to directly transform 68k 80-bit extended data types to double
  609.       and back for PowerPC based machines without using the functions
  610.       x80told or ldtox80.  Double rounding may occur.                         */
  611.  
  612. double x80tod ( const extended80 *x80 );
  613. void dtox80   ( const double *x, extended80 *x80 );
  614.  
  615. void num2decl ( const decform *f, long double x, decimal *d );
  616. long double dec2numl ( const decimal *d );
  617.  
  618. #endif      /* __NOEXTENSIONS__ */
  619.  
  620. #endif      /* GENERATINGPOWERPC  */
  621.  
  622. #ifdef __cplusplus
  623. }
  624. #endif
  625.  
  626. #endif      /* __FP__          */
  627.